草庐IT

Docker-Compose 重启策略

全部标签

ruby-on-rails - 在 Heroku 上重启后长时间运行的 delayed_job 作业保持锁定状态

当Herokuworker重新启动时(根据命令或作为部署的结果),Heroku将SIGTERM发送到worker进程。对于delayed_job,SIGTERMsignaliscaught然后工作人员在当前作业(如果有)停止后停止执行。如果工作人员需要很长时间才能完成,那么Heroku将发送SIGKILL。在delayed_job的情况下,这会在数据库中留下一个锁定的作业,不会被其他工作人员接收。我想确保作业最终完成(除非出现错误)。鉴于此,解决这个问题的最佳方法是什么?我看到两个选项。但我想获得其他输入:修改delayed_job以在收到SIGTERM时停止处理当前作业(并释放锁定)

ruby - 部署后 Capistrano 3 不重启

我最近更新了我的capistranogem到版本3.1.0,从那时起capproductiondeploy顺利通过,但目标deploy:restart没有被调用。我的服务器部署在AmazonEC2上的Ubuntu12.10上。为什么会这样? 最佳答案 Capistrano3默认不再运行该任务,因为许多应用服务器不需要它。将此添加到您的config/deploy.rb:after'deploy:publishing','deploy:restart'来自releasenotes:Breakingchanges:deploy:resta

ruby - 重启 Sidekiq

重启sidekiq的正确方法是什么。它似乎在我启动它时缓存了我的worker代码,所以每次我对我的worker进行更改时我都需要重新启动它。我正在使用Ctrl/C执行此操作,但该过程需要很长时间才能结束并返回到提示符。有没有办法立即强制重启?我使用的是通过POW运行的Sinatra的最新版本。 最佳答案 Sidekiq自带命令sidekiqctl,可以停止与你的Sidekiq进程关联的PID。您传入PID文件和等待所有线程完成的秒数。示例用法:sidekiqctlstop#{rails_root}/tmp/pids/sidekiq_

ruby - Docker for Mac - mkmf.rb 找不到 ruby​​ 的头文件

我在我的Mac上更新了XCode,从那时起,当使用docker-sync-stackstart启动Docker时,我收到了这个错误消息:mkmf.rbcan'tfindheaderfilesforrubyat/System/Library/Frameworks/Ruby.framework/Versions/2.0/usr/lib/ruby/include/ruby.h我尝试用这个安装ruby​​:brewinstallrbenvruby​​-build但这并没有改变任何东西。有人知道我该如何解决吗?谢谢! 最佳答案 对于ma​​c

ruby-on-rails - has_many 同时尊重 factory_girl 中的构建策略

情况#ModelsclassUser:user)do|u|u.items{|items|[items.association(:item),items.association(:item)]}endFactory.define(:item)do|i|i.color"red"endFactory.define(:item_with_user,:parent=>:user)do|i|i.association(:user)end问题如果您运行@user=Factory(:user_with_items),则@user.items包含这两个项目。问题是这些项目未与数据库中的用户相关联。如果你

ruby-on-rails - 用 USR2 重启 Unicorn - 退出 old master

因此,将USR2发送给Unicorn非常棒——它会使用您的代码的新副本启动一个新的master,并自动获取任何更改。甜的。我的问题是:我如何阻止老主人?显然被接受的方式是在before_fork中:before_forkdo|server,worker|old_pid='/var/www/current/tmp/pids/unicorn.pid.oldbin'ifFile.exists?(old_pid)&&server.pid!=old_pidbeginProcess.kill("QUIT",File.read(old_pid).to_i)rescueErrno::ENOENT,Er

ruby-on-rails - 覆盖 database.yml 的策略?

在我的环境中,部署服务器具有database.yml中的大部分连接信息。即他们知道自己是开发、测试还是生产服务器,知道各自的数据库连接信息。例如,我可以将此信息封装在一个服务器类中,以便我可以检索信息:Server["environment"]#=>productionServer["db_host"]#=>db5.example.comServer["db_password"]#=>[adecryptedpassword]等等。我想部署一个Rails应用程序并让它根据服务器设置自动配置。执行此操作的最佳方法是什么?一种方法是在我的database.yml中使用Erb::adapter

Azure B2C MFA在用户级别和登录策略级别

我有一个Web应用程序,该应用程序可以通过MFA在登录策略级别(此时在用户级别禁用MFA)的B2C租户进行身份验证,并且该策略被配置为使用“用户名”来登录。该应用程序正常工作并且用户能够登录...我要完成的工作是在用户级别上拥有MFA,这意味着只有某些用户可以使用MFA,而其他用户可以在没有MFA的情况下登录。当我在用户级别打开MFA并在登录策略级别上关闭MFA时,我面临的问题是MFA在用户级别第一个密码身份验证屏幕后,重定向到多因素身份验证屏幕,要求用户将代码发送到失败。取而代之的是,它将返回第一个密码身份验证屏幕,并且似乎处于循环中。关闭两个MFA时,它可以通过密码身份验证效果很好,并且用

把java项目打包成镜像在docker中运行

1,首先要准备一个maven项目,把它打成jar包如下图:找Maven->package->运行好了之后下面有路径。 2,在docker下创建一个目录mkdir  /mydocker3,把打包好的java项目用Xtfp(这是一个软件,专门用来连接虚拟机上传文件的)把那个jar包拉到 /mydocker下面   连接好了之后直接找到那个jar包 直接拉过去4,然后在同一目录下建一个文件vim Dockerfile 5,并进行编辑(这个文件非常的重要!!!)#基础镜像使用javaFROM java:8#作者MAINTAINER xiaoliu# VOLUME指定临时文件目录/tmp 在主机/var

ruby-on-rails - 设计的自定义身份验证策略

我需要为https://github.com/plataformatec/devise编写自定义身份验证策略但似乎没有任何文档。怎么做到的? 最佳答案 我在thisthread中找到了这个非常有用的片段在设计谷歌组初始化器/some_initializer.rb:Warden::Strategies.add(:custom_strategy_name)dodefvalid?#codeheretocheckwhethertotryandauthenticateusingthisstrategy;returntrue/falseendd